# Bridging HW and SW verification with VUnit co-simulation

**Unai Martinez-Corral** 

#### About me

- Digital Electronics Design Group (GDED) at the University of the Basque Country (UPV/EHU) [unai.martinezcorral@ehu.eus]
- Antmicro [umartinezcorral@antmicro.com]
- GitHub: GHDL, VUnit, HDL, VHDL, EDA<sup>2</sup>, F4PGA...
   [@umarcor]
- GitLab: IEEE-P1076 [@umarcor]

#### **VHDL**

# Verification and Hardware Description Language

Computer language

Software and/or hardware

#### HDL co-simulation

- Indirect co-simulation:
  - Verilog Procedural Interface (VPI), also known as Program Language Interface (PLI)
     2.0.
  - VHDL Procedural Interface (VHPI).
- Direct co-simulation:
  - Specific implementations of (a draft of) VHPIDIRECT, such as Foreign Language Interface (FLI) or Xilinx Simulation Interface (XSI).
  - Direct Programming Interface (DPI).
- Generation of C/C++ models/sources through a transpiler.
  - Verilated models.
  - CXXRTL (Yosys).
  - o "Mixed-language" simulation.

#### GHDL: a VHDL toolkit



umarcor.github.io/SIEAV/VHDL.html

# GHDL: compiling and executing VHDL



## GHDL co-simulation [ghdl.github.io/ghdl-cosim]

#### VHPIDIRECT

- Have the signature of a VHDL subprogram match a foreign language.
- Where and when to execute foreign functions is defined in VHDL.
- With LLVM or GCC backends, foreign code can be provided as C/Ada sources, or called through a shared library.

#### VPI

- Use a C API to register callback functions.
- Where and when to execute the callbacks is defined in the foreign language.
- Foreign code is compiled into a shared library.

#### ghdl\_main

- Wrap the whole simulation by calling GHDL as a function.
- Execution is always managed by GHDL.

#### Functional verification of an HDL design







# Digital twins



# VUnit: an open source unit testing framework for HDLs



vunit.github.io/about.html

## Array and AXI4 Stream Verification Components

ghdl-cosim's vunit\_axis\_vcs



ghdl.github.io/ghdl-cosim/vhpidirect/examples/array s.html#array-and-axi4-stream-verification-componen ts



#### ghdl/ghdl-cosim: vhpidirect/arrays/matrices/vunit\_axis\_vcs/run.py

```
from pathlib import Path
from vunit import VUnit
VU = VUnit.from argv(vhdl standard="2008")
VU.add verification components()
ROOT = Path( file ).resolve().parent
VU.add library("lib").add source files([ROOT.parent / "pkg.vhd", ROOT / "src" / "*.vhd", ROOT
/ "*.vhd"])
VU.set compile option("ghdl.flags", ["-frelaxed"])
VU.set_sim_option("ghdl.elab_flags", ["-frelaxed", "-WI," + str(ROOT.parent / "main.c")])
VU.main()
```

# Building the HDL design/simulation as shared lib

```
vu.set sim option('ghdl.elab flags', [
    '-shared'.
     '-WI,-fPIC',
    '-WI,' + str(ROOT.parent.parent.parent / 'quickstart' / 'wrapping' / 'exitcb' /
'caux.c')
vu.set sim option("ghdl.elab e", True)
vu. args.elaborate = True
```

ghdl/ghdl-cosim: vhpidirect/shared/py/vunit/run.py ghdl/ghdl-cosim: vhpidirect/shared/py/vunit/cosim.py

# VGA (RGB image buffer)¶

ghdl.github.io/ghdl-cosim/vhpidirect/examples/arrays.html#vga-rgb-image-buffer github.com/dbhi/vboard: vga



### matplotlib

```
def plotxy(x, y, l):
    print("plotxy", x, y, l)

xx = np.ctypeslib.as_array((ctypes.c_int * l).from_address(ctypes.addressof(x.contents)))
yy = np.ctypeslib.as_array((ctypes.c_int * l).from_address(ctypes.addressof(y.contents)))

plt.title("ghdl-cosim Python callback example")
plt.xlabel("x axis caption")
plt.ylabel("y axis caption")
plt.plot(xx,yy)
```

ghdl/ghdl-cosim: vhpidirect/shared/pycb/run.py

# Virtual development board



#### github.com/dbhi/vboard

- Virtual Nexys-4 like board [https://gitlab.ensta-bretagne.fr/bollenth/ghdl-vpi-virtual-board]
- An Interactive VHDL Testbench Using GHDL, Python, and Cocotb [https://blog.chuckstechtalk.com/software/2021/12/27/interactive-vhdl-testbench.html]
- Visualization of hyperspectral/multispectral image processing cores [https://github.com/VUnit/vunit/pull/568]

## Open Source Verification Bundle

umarcor.github.io/osvb





#### Additional content



Cosimulation and verification of SoCs on FPGA

#### github.com/umarcor/sieav

- umarcor.github.io/SIEAV/
- github.com/umarcor/SIEAV/releases/tag/tip

#### Additional content

- Xyce
- DBHI
- Renode
- vunit/cosim
- vunit/vunit\_action